CASE 3156 PATENT

## **CLAIMS**

## What is claimed is:

| 1.           | An I/O interface for an integrated circuit chip having a core, a pad, |
|--------------|-----------------------------------------------------------------------|
| and a data l | ouffer disposed between the core and the pad, the data buffer         |
| comprising   |                                                                       |
|              | an output circuit including:                                          |
|              | a plurality of output latches, each output latch having at least      |
|              | one input coupled to receive output data signals from                 |
|              | the core;                                                             |
|              | a plurality of output clock trees, each output clock tree             |
|              | coupled to at least one of the output latches for                     |
|              | triggering the latching of the output data signals from               |
|              | the core, each output clock tree disposed in the I/O                  |
|              | interface;                                                            |
|              | a first signal conditioning circuit coupled to the output latches     |
|              | for conditioning the output data signals so that the                  |
|              | output data signals are compliant with at least one of a              |
|              | plurality of protocols;                                               |
|              | an input circuit including:                                           |
|              | a plurality of input latches, each input latch having at least one    |
|              | input coupled to receive input data signals from the                  |
|              | pad;                                                                  |
|              | and a data l                                                          |



| CASE 3156 |  |
|-----------|--|
|           |  |

| 21         | an input clock tree coupled to at least one of the input latches                    |
|------------|-------------------------------------------------------------------------------------|
| 22         | for triggering the latching of the input data signals from                          |
| 23         | the pad; and                                                                        |
| 24         | a second signal conditioning circuit coupled to the input                           |
| 25         | latches for conditioning the input data signals so that                             |
| 26         | the input data signals are compliant with at least one of                           |
| 27         | the plurality of protocols:                                                         |
| 1          | 2. The I/O interface of claim 1, wherein the input clock tree distributes           |
| 2          | to the data buffer a clock/strobe signal generated from a source external to the    |
| 3<br>      | I/O interface.                                                                      |
| 1          | 3. The I/O interface of claim 1, wherein the output data signals and the            |
| <b>1</b> 2 | input data signals are conditioned by the first signal conditioning circuit and the |
| 3          | second signal conditioning circuit, respectively, to be compliant with a protocol   |
| 4          | that is selected on-the-fly.                                                        |
| 1          | 4. The I/O interface of claim 3, wherein the protocol is selected from              |
| 2          | the group of protocols consisting of AGP, DDR/SSTL, and PCI/TTL.                    |
| 1          | 5. The I/O interface of claim 4, wherein the data buffer operates in a              |
| 2          | synchronous mode for AGP and DDR/SSTL protocols, and the data buffer                |
|            |                                                                                     |

operates in an asynchronous mode for PCI/TTL protocol.

9

10

11

| 3 |  |
|---|--|
| 4 |  |
| 5 |  |
| 6 |  |
| 1 |  |
| 2 |  |
| 1 |  |
| 2 |  |
| 1 |  |
| 2 |  |
| 3 |  |
| 4 |  |
| 5 |  |
| 6 |  |
| 7 |  |
| 8 |  |

| 1 | 6. The I/O interface of claim 1, wherein the output circuit includes a                |
|---|---------------------------------------------------------------------------------------|
| 2 | first output latch, a second output latch, and a third output latch, the first output |
| 3 | latch and the second output latch each coupled to a first output clock tree, the      |
| 4 | third output latch coupled to a second output clock tree, the output clock trees      |
| 5 | for triggering the latching of the output data signals from the core in a             |
| 5 | synchronous manner                                                                    |

- 7. The I/O interface of claim 6, wherein the first clock tree provides a double rate clock and the second clock tree provides a single rate clock.
- 8. The I/O interface of claim 6, wherein the first output latch, the second output latch, and the third output latch are edge-triggered flip-flops.
- 9. The I/O interface of claim 1, wherein the first signal conditioning circuit comprises:
  - a pre-driver having an input and an output, the input coupled to the output latches for receiving the output data signals;
  - a voltage tolerant circuit having an input and an output, the input coupled to the output of the pre-driver for receiving output data signals; and
  - a driver circuit having an input and an output, the input coupled to the output of the voltage tolerant circuit for receiving the output data signals, the output of the

2

3

4

1

- driver circuit coupled to the pad for providing a pad
  voltage compliant with one of the plurality of protocols.
  - 1 10. The I/O interface of claim 9, wherein the voltage tolerant circuit is
    2 further coupled to the pad via a switching well, the switching well operating in
    3 conjunction with the voltage tolerant circuit and the driver circuit to compare the
    4 pad voltage with a supply voltage and switching the higher of the two voltages
    5 to the switching well.
    - 11. The I/O interface of claim 10, wherein the switching well is further coupled to a pull-up/pull-down circuit for adjusting the pad voltage.
    - 12. The I/O interface of claim 11, wherein the pull-up/pull-down circuit includes a pull-up resistor and a pull-down resistor, each resistor responsive to an enabling signal from the core.
    - 13. The I/O interface of claim 1, wherein the input circuit includes a first input latch, a second input latch, and a third input latch, each input latch coupled to the input clock for triggering the latching of the input data signals from the pad in a synchronous manner.
  - 1 14. The I/O interface of claim 1, wherein the input circuit includes a
    2 Schmitt trigger coupled to the pad for receiving input data signals compliant
    3 with PCI/TTL protocol.

CASE 3156 PATENT

| 1                                                                                           | 15. The I/O interface of claim I, wherein the input circuit includes a          |
|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| 2                                                                                           | differential amplifier coupled to the pad for receiving differential input data |
| 3                                                                                           | signals.                                                                        |
|                                                                                             |                                                                                 |
| 1                                                                                           | 16. An I/O interface for an integrated circuit chip having a core, a pad,       |
| 2                                                                                           | and a clock/strobe buffer disposed between the core and the pad, the            |
| 3                                                                                           | clock/strobe buffer comprising:                                                 |
| 4                                                                                           | a differential amplifier having an input and an output, the                     |
| ₫ 5                                                                                         | input coupled to the pad for receiving differential                             |
| ₩<br><b>©</b> 6                                                                             | clock/strope signals complying with one of a plurality                          |
| 네<br>일 7                                                                                    | of protocols;                                                                   |
| 3<br>3<br>3<br>3<br>5<br>6<br>7<br>8<br>9                                                   | a programmable delay module having inputs and an output, a                      |
| 9                                                                                           | first input coupled to the output of the differential                           |
| □<br><b>=</b> 10                                                                            | amplifier for receiving the clock/strobe signals, a                             |
| 了<br>了<br>了<br>了<br>了<br>了<br>了<br>了<br>了<br>了<br>了<br>了<br>了<br>了<br>了<br>了<br>了<br>了<br>了 | second input for receiving a plurality of program bits                          |
| <u> </u>                                                                                    | for delaying the clock strobe signals; and                                      |
| 13                                                                                          | a gated buffer coupled to the output of the programmable                        |
| 14                                                                                          | delay module and an input clock tree, the gated buffer                          |
| 15                                                                                          | for distributing the clock/strobe signals to the I/O                            |
| 16                                                                                          | interface via the input clock tree.                                             |
| 1                                                                                           | 17. The I/O interface of claim 16, wherein the protocol is selected from        |
| 2                                                                                           | the group of protocols consisting of AGP and DDR/SSTL.                          |

CASE 3156

PATENT

| 18. The I/O interface of claim 16, wherein the clock/strobe buffer             |
|--------------------------------------------------------------------------------|
| further includes a Schmitt trigger coupled to the pad and the gated buffer for |
| receiving TTL clock/strobe signals from the pad and distributing the TTL       |
| clock/strobe signals to the I/O interface via the input clock tree.            |
| 19. An I/O interface for an integrated circuit chip having a core, a pad,      |
| and a clock/strobe buffer disposed between the core and the pad, the           |
| clock/strobe buffer comprising:                                                |
| an output circuit including:                                                   |
| an output latch having at least one input coupled to receive                   |
| output clock/strobe signals from the core, the output                          |
| latch coupled to a kirst clock tree for triggering the                         |
| latching of the output clock/strobe signals from the                           |
| core, the first output clock tree disposed in the I/O                          |
| interface;                                                                     |
| a multiplexed having at least one input coupled to a second                    |
| clock tree, the multiplexer for reducing the skew on the                       |
| clock/strobe signals, the second output clock tree                             |
| disposed in the I/O interface;                                                 |
| a first signal conditioning circuit coupled to the output latch                |
| and the multiplexed for conditioning the output                                |
| clock/strobe signals so that the output clock/strobe                           |
| signals are compliant with at least one of a plurality of                      |
| protocols;                                                                     |
|                                                                                |

| 20                                             | an input circuit including:                                                    |
|------------------------------------------------|--------------------------------------------------------------------------------|
| 21                                             | a differential amplifier having an input and an output, the                    |
| 22                                             | input coupled to the pad for receiving differential                            |
| 23                                             | clock strobe signals complying with one of a plurality                         |
| 24                                             | of protocols; and                                                              |
| 25                                             | a gated buffer coupled to the output of the differential                       |
| 26                                             | amplifier and an input clock tree, the gated buffer for                        |
| 27                                             | distributing the clock/strobe signals via the input clock                      |
| 28                                             | tree .                                                                         |
| 1                                              | 20. The I/O interface of claim 19, wherein the protocol is selected from       |
| , just 1904 1904 1904 1904 1904 1904 1904 1904 | the group of protocols consisting of AGP and DDR/SSTL.                         |
| 1                                              | 21. The I/O interface of claim 19, wherein the clock/strobe buffer             |
| 2                                              | further includes a Schmitt trigger coupled to the pad and the gated buffer for |
| 3                                              | receiving TTL clock/strobe signals from the pad and distributing the           |
| 4                                              | clock/strobe signals to the I/O interface via the input clock tree.            |

